Exceptions Logging এবং Debugging Techniques গাইড ও নোট

Computer Programming - রুবি প্রোগ্রামিং (Ruby Programming) - Exception Handling (এক্সেপশন হ্যান্ডলিং)
252

Exceptions Logging এবং Debugging Techniques হল সফটওয়্যার ডেভেলপমেন্টে গুরুত্বপূর্ণ কৌশল, যা কোডের ত্রুটি (error) এবং সমস্যাগুলো চিহ্নিত এবং সমাধান করতে ব্যবহৃত হয়। রুবি প্রোগ্রামিং ভাষায় এ দুটি প্রক্রিয়া কার্যকরভাবে ব্যবহার করা যেতে পারে কোডের কার্যকারিতা নিশ্চিত করতে এবং উৎপাদন পরিবেশে (production environment) ত্রুটি সমাধান করতে।


১. Exceptions Logging

Exceptions Logging হল সেই প্রক্রিয়া যেখানে কোডের মধ্যে ত্রুটি ঘটলে তার বিস্তারিত তথ্য লগ (log) আকারে সংরক্ষণ করা হয়। এটি ডেভেলপারদের ত্রুটি শনাক্ত করতে সহায়তা করে, যাতে ত্রুটির কারণ বোঝা যায় এবং ভবিষ্যতে তা সমাধান করা যায়।

রুবি ভাষায় ত্রুটির লগ করার জন্য আপনি begin...rescue...end ব্লক ব্যবহার করতে পারেন, এবং লগ তথ্য সংরক্ষণ করতে Logger ক্লাস ব্যবহার করা হয়।

১.১ Logger ক্লাস ব্যবহার করে Exception Logging

রুবির Logger ক্লাসটি ত্রুটির তথ্য (exception) লগ করার জন্য একটি সুবিধাজনক উপায় প্রদান করে। এটি বিভিন্ন লগ স্তর (level) যেমন INFO, ERROR, DEBUG, ইত্যাদি সমর্থন করে।

Syntax:

require 'logger'

logger = Logger.new('logfile.log')  # Creating a new logger and specifying the log file

logger.level = Logger::ERROR   # Set the log level to ERROR (other levels can be INFO, DEBUG, etc.)

begin
  # Code that may raise an exception
  raise "Something went wrong!"
rescue => e
  logger.error("Error occurred: #{e.message}")  # Log the error message
end

উদাহরণ:

require 'logger'

logger = Logger.new('error_log.txt')  # Log file
logger.level = Logger::DEBUG         # Set the logging level to DEBUG

begin
  # Some code that might cause an exception
  result = 10 / 0  # Division by zero error
rescue ZeroDivisionError => e
  logger.error("Error: #{e.message}")   # Log the exception message as error
  logger.debug("Stack trace: #{e.backtrace.join("\n")}")  # Log the stack trace at the debug level
end

আউটপুট (error_log.txt):

Error: divided by 0
Stack trace: <stack trace details>

এখানে, logger.error ত্রুটির বার্তা এবং logger.debug স্ট্যাক ট্রেস সংরক্ষণ করেছে। লগ ফাইলটি এভাবে ত্রুটির তথ্য এবং ডিবাগ তথ্য সংরক্ষণ করে, যা ডেভেলপারদের ত্রুটি চিহ্নিত এবং সমাধান করতে সাহায্য করে।

Logger এর বিভিন্ন স্তর:

  • Logger::DEBUG: ডিবাগging স্তর, বিস্তারিত তথ্য লগ করে।
  • Logger::INFO: সাধারণ তথ্য লগ করে।
  • Logger::WARN: সতর্কতা লগ করে।
  • Logger::ERROR: ত্রুটি লগ করে।
  • Logger::FATAL: মারাত্মক ত্রুটি লগ করে।

২. Debugging Techniques (ডিবাগিং কৌশল)

ডিবাগিং হল প্রোগ্রামিংয়ের একটি প্রক্রিয়া, যেখানে কোডের ত্রুটি (bugs) শনাক্ত এবং সংশোধন করা হয়। রুবিতে কিছু কার্যকরী ডিবাগিং কৌশল রয়েছে, যা ডেভেলপারদের ত্রুটি চিহ্নিত করতে এবং সমস্যার সমাধান করতে সাহায্য করে।

২.১ puts এবং print ব্যবহার করে ডিবাগিং

একটি সাধারণ এবং প্রাথমিক ডিবাগিং কৌশল হল puts বা print মেথড ব্যবহার করে কোডের বিভিন্ন অংশের মান বের করা। এতে করে ডেভেলপাররা কোডের নির্দিষ্ট অংশের আউটপুট দেখতে পায় এবং ত্রুটি চিহ্নিত করতে সাহায্য পায়।

উদাহরণ:

def divide(a, b)
  puts "a = #{a}, b = #{b}"  # Debugging line
  result = a / b
  puts "result = #{result}"  # Debugging line
  result
end

divide(10, 2)

এখানে, puts মেথড ব্যবহার করে আমরা ভেরিয়েবল a, b, এবং result এর মান আউটপুট করে দেখতে পারি।


২.২ pry বা byebug ব্যবহার করে ডিবাগিং

pry এবং byebug হল দুইটি শক্তিশালী ডিবাগিং টুল, যা কোডের মধ্যে ব্রেকপয়েন্ট (breakpoint) সেট করতে এবং কোড লাইনে থেমে গিয়ে ডেটা পরীক্ষা করতে ব্যবহৃত হয়। এগুলি interactive debugging এর জন্য ব্যবহৃত হয়, যেখানে ডেভেলপার কোডের স্টেট চেক করতে পারেন।

pry এবং byebug ব্যবহারের জন্য আপনাকে তাদের ইনস্টল করতে হবে:

gem install pry
gem install byebug

উদাহরণ (pry):

require 'pry'

def divide(a, b)
  binding.pry   # Debugging breakpoint
  result = a / b
  result
end

divide(10, 2)

এখানে, binding.pry একটি ব্রেকপয়েন্ট যোগ করেছে, যেখানে কোড থেমে যাবে এবং আপনি ইন্টারঅ্যাকটিভভাবে কোডের ভেরিয়েবল চেক করতে পারবেন।

উদাহরণ (byebug):

require 'byebug'

def divide(a, b)
  byebug    # Debugging breakpoint
  result = a / b
  result
end

divide(10, 2)

এখানে, byebug ব্যবহৃত হয়েছে এবং ব্রেকপয়েন্টে থেমে গিয়ে আপনি বিভিন্ন ভেরিয়েবল পরীক্ষা করতে পারবেন এবং কোডের কার্যকারিতা পরীক্ষা করতে পারবেন।


২.৩ Error Backtrace Analysis

রুবিতে যখন কোনো ত্রুটি (error) ঘটে, তখন আপনি সেই ত্রুটির backtrace দেখতে পারেন। এটি আপনাকে ত্রুটির সঠিক অবস্থান এবং সেই অবস্থানে গিয়ে কিভাবে ত্রুটিটি ঘটেছে, তা বুঝতে সহায়তা করে।

উদাহরণ:

begin
  # Some code that might cause an exception
  result = 10 / 0  # Division by zero error
rescue ZeroDivisionError => e
  puts "Error message: #{e.message}"
  puts "Backtrace: #{e.backtrace.join("\n")}"
end

আউটপুট:

Error message: divided by 0
Backtrace: /path/to/file.rb:3:in `/'
/path/to/file.rb:3:in `block in <main>'

এখানে, e.backtrace দিয়ে আপনি ত্রুটির ঘটনার পুরো স্ট্যাক ট্রেস দেখতে পাচ্ছেন, যা ডিবাগিংয়ের জন্য খুবই সহায়ক।


সারসংক্ষেপ

  • Exception Logging: ত্রুটির লগ রাখার জন্য রুবির Logger ক্লাস ব্যবহৃত হয়। এটি ত্রুটি সংক্রান্ত তথ্য, যেমন ত্রুটি বার্তা এবং স্ট্যাক ট্রেস লগ করে, যা ডেভেলপারদের ত্রুটি চিহ্নিত এবং সমাধান করতে সহায়তা করে।
  • Debugging Techniques: ডিবাগিংয়ের জন্য puts, pry, byebug, এবং backtrace analysis ব্যবহার করা হয়। এগুলি ডেভেলপারদের কোডের ত্রুটি বা সমস্যাগুলি দ্রুত চিহ্নিত করতে এবং সমাধান করতে সহায়তা করে।

এই কৌশলগুলির মাধ্যমে আপনি ত্রুটি শনাক্ত এবং সমাধান করতে সক্ষম হবেন, যা কোডের উন্নয়ন এবং রক্ষণাবেক্ষণকে সহজ করে তোলে।

Content added By
Promotion

Are you sure to start over?

Loading...